/* ==============================
PÁGINA DE VIDEOS – GGE
============================== */
.videos-header { text-align: center; margin-bottom: 24px; }
.videos-header h1 { font-size: 2.2rem; color: var(--gge-gold-soft); margin-bottom: 10px; }
.videos-header p { color: #ccc; font-size: 0.95rem; max-width: 750px; margin: 0 auto; line-height: 1.5; }


.videos-tags { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; font-size: 0.8rem; }
.videos-tag { padding: 4px 10px; border-radius: 999px; border: 1px solid rgba(245,196,67,0.7); color: var(--gge-gold-soft); background: rgba(0,0,0,0.6); }


/* Filtros */
.videos-filtros { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 30px 0 35px; }
.videos-filtros button { background: #111; border: 1px solid #555; color: #eee; padding: 8px 16px; border-radius: 999px; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; cursor: pointer; transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s, box-shadow 0.2s, color 0.2s; }
.videos-filtros button:hover { background: var(--gge-gold-soft); border-color: var(--gge-gold-soft); color: #000; transform: translateY(-1px); box-shadow: 0 0 12px rgba(245,196,67,0.6); }
.videos-filtros button.activo { background: var(--gge-gold-soft); border-color: var(--gge-gold-soft); color: #000; box-shadow: 0 0 15px rgba(245,196,67,0.9); }


/* Grid de programas */
.programas-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; margin-bottom: 10px; }
@media (max-width: 992px) { .programas-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 600px) { .programas-grid { grid-template-columns: 1fr; } }


/* Tarjeta de programa */
.program-card { position: relative; background: radial-gradient(circle at top, #1b1b1b, #050505); border-radius: 18px; overflow: hidden; border: 1px solid #333; box-shadow: 0 0 12px rgba(0,0,0,0.9); cursor: pointer; display: flex; flex-direction: column; transition: transform 0.35s ease, border-color 0.3s ease, box-shadow 0.3s ease, opacity 0.4s ease, translate 0.3s ease; opacity: 0; transform: translateY(20px) scale(0.98); isolation: isolate; }
.program-card.visible { opacity: 1; transform: translateY(0) scale(1); transition: transform .55s ease, opacity .55s ease; }
.program-card.hidden { display: none; }
.program-card:hover { transform: translateY(-10px) scale(1.02); border-color: var(--gge-gold-soft); box-shadow: 0 0 26px rgba(245,196,67,0.8), 0 0 40px rgba(0,0,0,0.9); }


/* Borde premium vivo */
.program-card::before { content:""; position:absolute; inset: -1px; border-radius: 18px; background: linear-gradient(120deg, rgba(245,196,67,0.10), rgba(245,196,67,0.60), rgba(155,92,255,0.20), rgba(0,229,255,0.20), rgba(245,196,67,0.35)); opacity: 0; filter: blur(0.4px); z-index: -1; transition: opacity .35s ease; }
.program-card:hover::before { opacity: 1; }


/* Brillo superior suave */
.program-card::after { content:""; position:absolute; inset: 0; border-radius: 18px; background: radial-gradient(circle at 20% 0%, rgba(245,196,67,0.22), transparent 45%); opacity: 0.65; z-index: 0; pointer-events:none; }


/* Asegura contenido sobre el brillo */
.program-thumb, .program-info { position: relative; z-index: 1; }


/* Imagen / thumb */
.program-thumb { position: relative; width: 100%; height: 320px; overflow: hidden; background: radial-gradient(circle at center, #222, #000); display: flex; align-items: center; justify-content: center; }
.program-thumb img { width: 100%; height: 100%; object-fit: contain; transition: transform 0.4s ease, filter 0.4s ease, opacity 0.4s ease; }


/* Overlay con texto */
.program-overlay { position: absolute; inset: 0; background: radial-gradient(circle at center, rgba(245,196,67,0.35), transparent 55%), linear-gradient(to top, rgba(0,0,0,0.85), transparent); opacity: 0; transition: opacity 0.35s ease; display: flex; align-items: flex-end; padding: 16px; pointer-events: none; }
.program-overlay-text { font-size: 0.8rem; color: #f0f0f0; line-height: 1.4; }


/* Hover */
.program-card:hover .program-thumb img { transform: scale(1.07); filter: brightness(0.9); }
.program-card:hover .program-overlay { opacity: 1; }


/* Info bajo la imagen */
.program-info { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 4px; }
.program-nombre { font-size: 1rem; font-weight: 600; color: #fff; }
.program-meta { font-size: 0.8rem; color: #aaa; }


/* CTA y pill */
.program-cta-row { margin-top: 6px; display: flex; justify-content: space-between; align-items: center; gap: 6px; font-size: 0.82rem; }
.program-cta { font-size: 0.8rem; color: var(--gge-gold-soft); text-transform: uppercase; letter-spacing: 0.08em; display: inline-flex; align-items: center; gap: 6px; }
.program-cta span { font-size: 1rem; }
.program-pill { padding: 3px 9px; border-radius: 999px; border: 1px solid rgba(255,255,255,0.18); font-size: 0.75rem; color: #ddd; background: rgba(0,0,0,0.7); }


/* Barra de herramientas (buscador + contador) */
.videos-tools{ display:flex; justify-content:center; margin: 10px 0 18px; }
.videos-search-wrap{ width: min(820px, 100%); display:flex; gap: 12px; align-items:center; justify-content: space-between; padding: 12px 12px; border-radius: 16px; border: 1px solid rgba(245,196,67,0.25); background: rgba(0,0,0,0.55); box-shadow: 0 0 18px rgba(0,0,0,0.85); backdrop-filter: blur(6px); }
.videos-search{ flex: 1 1 auto; min-width: 180px; padding: 11px 12px; border-radius: 12px; border: 1px solid #333; outline: none; background: #0c0c0c; color: #fff; font-size: 0.95rem; }
.videos-search:focus{ border-color: rgba(245,196,67,0.9); box-shadow: 0 0 10px rgba(245,196,67,0.35); }
.videos-count{ flex: 0 0 auto; padding: 10px 12px; border-radius: 999px; border: 1px solid rgba(245,196,67,0.35); color: var(--gge-gold-soft); font-size: 0.85rem; letter-spacing: 0.04em; background: rgba(0,0,0,0.65); }


/* Badge por programa */
.program-badge{ position:absolute; top: 12px; left: 12px; padding: 6px 10px; border-radius: 999px; font-size: 0.75rem; letter-spacing: 0.06em; text-transform: uppercase; border: 1px solid rgba(255,255,255,0.18); background: rgba(0,0,0,0.55); color: #fff; backdrop-filter: blur(6px); box-shadow: 0 0 14px rgba(0,0,0,0.7); z-index: 2; }